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AMENDMENTS TO THE CLAIMS 

1- 55. (Cancelled) 

56. (Previously Presented) A binary content addressable memory (CAM) for 
storing ternary hierarchical addresses of a communication system therein and wherein each 
ternary hierarchical address comprises a communication system address and associated 
communication system address mask, said binary CAM comprising a plurality of entries 
wherein: 

each entry comprises: 

(1) a first value comprising the logically ANDed communication system 
address and its associated mask; and 

(2) a second value comprising the logically ANDed complement of said 
communication system address and its associated mask; and 

wherein each entry is positioned in said CAM based on the number of 
contiguous ones in said associated mask. 

57. (Previously Presented) The binary CAM of claim 56 wherein entries 
having the most amount of contiguous ones in said associated mask are located at the top 
of said CAM and wherein entries having the least amount of contiguous ones in said 
associated mask are located at the bottom of said CAM. 

58. (Previously Presented) The binary CAM of claim 57 wherein said first 
value comprises n bits and said second value comprises n bits and wherein each one of said 
bits in said first value has an associated bit in said second value, said each one of said bits 
and said associated bit forming a binary pair, said binary pair representing one bit of said 
address as two bits in said CAM. 
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59. (Previously Presented) The binary CAM of claim 58 wherein a 1 in said 
ternary hierarchical address is represented as 10 in said CAM, wherein a 0 in said ternary 
hierarchical address is represented as 01 in said CAM, and wherein a don't care in said 
ternary hierarchical address is represented as 00 in said CAM. 

60. (Previously Presented) The binary CAM of claim 58 wherein said first 
value is stored in an upper portion of said entry and said second value is stored in a lower 
portion of said entry. 

61. (Previously Presented) The binary CAM of claim 60 wherein said entry 
comprises 64 bits and wherein n is 32. 

62. (Previously Presented) A binary content addressable memory (CAM) for 
storing ternary hierarchical addresses of a communication system therein and wherein each 
ternary hierarchical address comprises a communication system address and associated 
communication system address mask, said binary CAM comprising a plurality of entries 
wherein: 

each entry comprises a two bit representation for each bit in said ternary 
hierarchical address; and 

wherein each entry is positioned in said CAM based on the number of 
contiguous ones in said associated mask. 

63. (Previously Presented) The binary CAM of claim 62 wherein: 

(a) a 1 in said ternary hierarchical address is represented by said two bit 
representation in said CAM as 10; 

(b) a 0 in said ternary hierarchical address is represented by said two bit 
representation in said CAM as 01; and 
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(c) a don't care in said ternary hierarchical address in represented by said two bit 
representation in said CAM as 00. 

64. (Previously Presented) The binary CAM of claim 63 wherein entries 
having the most amount of contiguous ones in said associated mask are located at the top 
of said CAM and wherein entries having the least amount of contiguous ones in said 
associated mask are located at the bottom of said CAM. 

65. (Previously Presented) A method for storing ternary hierarchical 
addresses of a communication system in a binary CAM wherein each ternary hierarchical 
address comprises a communication system address and associated communication system 
address mask, said method comprising the steps of: 

logically ANDing each communication system address and its associated mask to 
form a first value; 

logically ANDing the complement of each communication system address and 
its associated address mask to form a second value; and 

storing said first value and said second value in an entry in said binary CAM 
based on the number of contiguous ones in said address mask. 

66. (Previously Presented) The method of claim 65 wherein said step of 
storing said first value and said second value at a location comprises arranging entries such 
that entries having the most contiguous ones in said associated mask are located at the top 
of said CAM and wherein entries having the least amount of contiguous ones in said 
associated mask are located at the bottom of said CAM. 

67. (Previously Presented) The method of claim 66 wherein said first value 
comprises n bits and said second value comprises n bits and wherein said step of storing 
said first value and said second value comprises associating each one of said bits in said first 
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value with one bit in said second value to form a binary pair, said binary pair representing 
one bit of said address as two bits in said CAM. 

68. (Previously Presented) The method of claim 67 wherein said step of 
representing one bit of said ternary hierarchical address as two bits in said CAM comprises: 

(a) utilizing 10 in said CAM to represent a 1 in said ternary hierarchical address; 

(b) utilizing 01 in said CAM to represent a 0 in said ternary hierarchical 
address; and 

(c) utilizing 00 in said CAM to represent a don't care in said ternary hierarchical 

address. 

69. (Previously Presented) The method of claim 67 wherein said step of 
storing said first value and said second value comprises storing said first value in an upper 
portion of said entry and storing said second value in a lower portion of said entry. 

70. (Previously Presented) The method of claim 69 wherein said entry 
comprises 64 bits and wherein said step of storing said first value and said second value 
comprises storing said first value in the upper 32 bits and storing said second value in the 
lower 32 bits. 

71. (Previously Presented) A method of storing for storing ternary 
hierarchical addresses of a communication system in a binary CAM wherein each ternary 
hierarchical address comprises a communication system address and associated 
communication system address mask, said method comprising the steps of: 

(a) generating a CAM entry for each ternary hierarchical address by: 

(1) identifying that portion of each ternary hierarchical address that are 

don't cares; 



Application No.: Not Yet Assigned Docket No.: M4065.0573/P573-B 

(2) representing each bit in said ternary hierarchical address using bits in 
said CAM wherein: 



CAM; 



CAM; and 



00 in said CAM; 



(i) a 1 in said ternary hierarchical address is represented as 10 in said 



(ii) a 0 in said ternary hierarchical address is represented as 01 in said 



(iii) a don't care in said ternary hierarchical address is represented as 



(b) positioning each CAM entry in said CAM based on the number of 
contiguous ones in said associated mask. 

72. (Previously Presented) The method of claim 71 wherein said step of 
positioning each CAM entry in said CAM comprises arranging entries such that entries 
having the most contiguous ones in said associated mask are located at the top of said 
CAM and wherein entries having the least amount of contiguous ones in said associated 
mask are located at the bottom of said CAM. 

73. (Previously Presented) A method of searching a binary CAM to find a 
match for a ternary hierarchical address of a communication system, said binary CAM 
comprising entries of ternary hierarchical addresses, each ternary hierarchical address entry 
comprising a communication system address and an associated communication system 
address mask, said entries of ternary hierarchical addresses being stored in said binary CAM 
as a first value and a second value, said first value comprising the communication system 
address logically ANDed with said address mask and said second value comprising the 
complement of said communication system address logically ANDed with said address 
mask, and wherein all of said entries are ordered in said binary CAM based on the number 
of contiguous ones in said mask, said method comprising the steps of: 
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(a) loading a first register with the communication system address to be 
searched along with the complement of the communication system address; 

(b) loading a second register with the communication system address to be 
searched along with the complement of the communication system address; 

(c) associating each bit of said first register with one bit of said second register 
and with one bit of each entry in said binary CAM; 

(d) determining whether a bit match occurs between corresponding bits of said 
first register and each entry in said binary CAM as qualified by said corresponding bit of 
said second register; and 

(e) obtaining a match between the desired ternary hierarchical address and one 
of said entries based on the greatest number of matches of corresponding bits of said first 
register and each entry in said binary CAM. 

74. (Previously Presented) The method of claim 73 wherein said step of 
determining whether a bit match occurs between corresponding bits of said first register 
and each entry in said binary CAM as qualified by said corresponding bit of said second 
register comprises declaring a bit match between corresponding bits of said first register 
and each entry in said binary CAM: 

(1) if the corresponding bit in said second register is a 1; or 

(2) if the corresponding bit in said second register is a 0 and the corresponding 
bits of said first register and each entry in said binary CAM are identical. 

75. (Previously Presented) The method of claim 74 wherein said steps of 
loading a first and second register comprises loading the communication system address to 
be searched in an upper portion of said registers and loading said complement of the 
communication system address in a lower portion of said registers. 
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76. (Previously Presented) The method of claim 75 wherein said first and 
second registers comprise 64 bits and wherein said steps of loading said first and second 
registers comprises loading the communication system address to be searched in the upper 
32 bits of said registers and loading said complement of the communication system address 
in said lower 32 bits of said registers. 

77. (Previously Presented) A method of searching a binary CAM to find a 
match for a ternary hierarchical address of a communication system, said binary CAM 
comprising entries of ternary hierarchical addresses, each ternary hierarchical address 
comprising a communication system address and an associated communication system 
address mask, each ternary hierarchical address entry being stored in said binary CAM 
whereby 10 is stored in said entry for every 1 in said ternary hierarchical address, 01 is 
stored in said entry for every 0 in said ternary hierarchical address, and 00 is stored in said 
entry for every don't care in said ternary hierarchical address, and wherein all of said entries 
are ordered in said binary CAM based on the number of contiguous ones in said mask, said 
method comprising the steps of: 

(a) loading a first register and second register with the communication system 
address to be searched by: 

(1) loading a 10 in said first and second registers for every 1 in the 
ternary hierarchical address to be searched; 

(2) loading a 01 in said first and second registers for every 0 in the 
ternary hierarchical address to be searched; 

(3) loading a 00 in said first and second registers for every don't care in 
the ternary hierarchical address to be searched; 

(b) associating each bit of said first register with one bit of said second register 
and with one bit of each entry in said binary CAM; 
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(c) declaring a bit match between corresponding bits of said first register and 
each entry in said binary CAM: 

(1) if the corresponding bit in said second register is a 1; or 

(2) if the corresponding bit in said second register is a 0 and the 
corresponding bits of said first register and each entry in said binary CAM are identical; and 

(d) obtaining a match between the desired ternary hierarchical address and one 
of said entries based on the greatest number of matches of corresponding bits of said first 
register and each entry in said binary CAM. 

78. (Previously Presented) A method for maintaining a sorted CAM to 
enable longest matches in a single search cycle when hierarchical addresses are added to, or 
deleted from, the CAM in a communication system utilizing hierarchical addresses and 
associated address masks, said method comprising the steps of: 

(a) segmenting the CAM into blocks wherein each block corresponds to a single 
hierarchical mask and wherein said blocks are arranged in the CAM such that the lowest 
CAM addresses contain the highest hierarchical masks and the highest CAM addresses 
contain the lowest hierarchical masks; 

(b) storing hierarchical addresses according to said block having a corresponding 
hierarchical mask; and 

(c) tracking the first address and the next free address of each of said blocks and 
the size of each of said blocks. 

79. (Previously Presented) A content addressable memory (CAM) of a 
communications system utilizing ternary hierarchical addressing and associated address 
masks, said CAM comprising: 
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a plurality of address entries and associated address masks that are arranged in 
said CAM by mask number, with address entries having the highest mask number being 
located at address entry locations at the top of the CAM and address entries having the 
lowest mask number being located at address entry locations at the bottom of the CAM, 
said mask number being defined as the number of contiguous ones in an associated address 
mask, 

80. (Previously Presented) An apparatus for storing a plurality of address 
entries and associated address masks in a communication system utilizing ternary 
hierarchical addressing and associated address masks, said apparatus comprising: 

a binary CAM; 

a binary-encoded ternary converter coupled to said binary CAM wherein said 
binary-encoded ternary converter converts each ternary value into a corresponding binary- 
encoded ternary value to form said address entries; and 

wherein said plurality of address entries and associated address masks are 
arranged in said binary CAM in a plurality of address entry groups, each address entry 
group having a respective mask number, with said address entry group having the highest 
mask number being located at the highest location of the CAM and said address entry 
group having the lowest mask number being located at the lowest location of the CAM, 
said mask number being defined as the number of contiguous ones in an associated address 
mask. 



81. (Previously Presented) A method for accelerating the routing of 
hierarchical addressing in a communication system which utilizes ternary hierarchical 
addressing and associated address masks, said method comprising the steps of: 

(a) obtaining communication system hierarchical addresses and associated masks 
to form a plurality of address entries; and 
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(b) storing said plurality of address entries in a content-addressable memory 
(CAM) device by mask number wherein said mask number is defined as the number of 
contiguous ones in an associated address mask and wherein address entries having the 
highest mask number are stored in address entry locations at the highest location of the 
CAM and address entries having the lowest mask number are stored at address entry 
locations at the lowest location of the CAM. 

82. (Previously Presented) A content addressable memory (CAM) of a 
communication system as defined in claim 79 wherein said plurality of address entries 
comprises: 

a first group of address entries sharing a first said address mask and a second 
group of address entries sharing a second said address mask, said first and second groups 
being located at different locations of the CAM. 

83. (Previously Presented) A content addressable memory (CAM) of a 
communication system as defined in claim 82 further comprising at least one vacant 
address entry location disposed within said CAM between said first and second groups of 
address entries. 

84. (Previously Presented) An apparatus for storing a plurality of address 
entries and associated address masks in a communication system as defined in claim 80 
further comprising: 

at least one vacant address entry location within said CAM adjacent at least one 
of said address entry groups. 

85. (Previously Presented) A method for accelerating the routing of 
hierarchical addressing in a communication system as defined in claim 81 further 
comprising the steps of: 

receiving an address value in a comparand register of said CAM; 
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matching a further plurality of addresses, including a subset of said 
communication system hierarchical addresses, to said address value; and 

outputting an output hierarchical address of said further plurality of addresses 
according to respective storage locations of said further plurality of addresses. 

86. (Previously Presented) A method for accelerating the routing of 
hierarchical addressing in a communication system as defined in claim 85 wherein said 
output hierarchical address of said further plurality has a storage location lowest among 
said respective storage locations of said further plurality of addresses. 

87. (Previously Presented) A method for accelerating the routing of 
hierarchical addressing in a communication system as defined in claim 85 wherein said 
further plurality of said communication system hierarchical addresses each includes at least 
one identical bit. 
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